草庐IT

php - 在sql中添加数字

全部标签

ruby - 当字符串包含数字时,为什么 Ruby 的 String#to_i 有时会返回 0?

我刚刚尝试使用Ruby,然后遇到了String#to_i。假设我有这段代码:var1='6sldasdhkjas'var2='aljdfldjlfjldsfjl6'为什么putsvar1.to_i输出6而putsvar2.to_i给出0? 最佳答案 to_i方法返回由字符串开头处的所有可解析数字组成的数字。您的第一个字符串以带有数字的a开头,因此to_i返回该字符串,第二个字符串不以数字开头,因此返回0。顺便说一句,空格被忽略,所以"123abc".to_i返回123. 关于ruby-当

ruby - 如何使用 Ruby 检查字符串中是否至少包含一个数字?

我需要使用Ruby检查字符串中是否至少包含一个数字(我假设是某种正则表达式?)。我该怎么做? 最佳答案 您可以使用String类的=~方法,并将正则表达式/\d/作为参数。这是一个例子:s='abc123'ifs=~/\d/#CallingString's=~method.puts"TheString#{s}hasanumberinit."elseputs"TheString#{s}doesnothaveanumberinit."end 关于ruby-如何使用Ruby检查字符串中是否至少

ruby - 如何在 ruby 中将一位数字变成两位数字?

Time.new.month返回10月之前任何月份的一位数表示(例如6月是6),但我想要一个2位数格式(即而不是6我想要06)。我写了下面的解决方案,我想看看其他/更好的解决方案。s=6.to_s;s[1]=s[0];s[0]='0';s#=>'06' 最佳答案 为了你的需要我觉得最好的还是Time.strftime("%m")如前所述,但对于一般用例,我使用的方法是str=format('%02d',4)putsstr根据上下文,我也使用这个做同样事情的:str='%02d%s%04d'%[4,"astring",56]putss

ruby-on-rails - 如何清理 Rails 4 中的原始 SQL

在Rails3中,我可以使用sanitize_sql_array为那些偶尔需要原始SQL查询的时刻清理原始SQL。但这似乎已在Rails4中删除,或者没有删除太多,而是移至ActiveRecord::Sanitization。但是,我现在不知道如何调用sanitize_sql_array,那么在Rails4中清理原始SQL的最佳方法是什么?我想澄清一下,我在这里谈论的是完整的原始SQL查询,而不是使用Rail的模型。我知道这不是最佳实践,这正是我必须为这个特定查询做的事情,因为它不能用Rails漂亮的ActiveRecord接口(interface)表示(相信我,我已经试过了)。这是一

ruby-on-rails - Rails 5.2 Active Storage 添加自定义属性

我有一个带有附件的模型:classProject当我附加并保存图像时,我还想保存附加的自定义属性-display_order(整数)和附加图像。我想用它来对附加的图像进行排序,并按照我在此自定义属性中指定的顺序显示它们。我已经查看了#attach方法以及ActiveStorage::Blob模型的ActiveStorage源代码,但看起来没有内置方法来传递一些自定义元数据。我想知道,用ActiveStorage解决这个问题的惯用方法是什么?在过去,我通常只是将display_order属性添加到代表我的附件的ActiveRecord模型,然后简单地将它与.order(display_o

sql - Ruby 中的 pretty-print SQL

有没有一种简单的方法可以在(rails3)控制台中pretty-print随机SQL?类似于awesome_print的内容,甚至可能是PrettyPrint.它不需要理解所有可能的方言或非常高级。我真正想要的是更轻松地检查ActiveRecord生成的SQL。目前我只是将SQL复制到网上进行格式化,这显然是生产力killer。我真的很想query.to_sql.pretty_format_sql并查看更好的输出。谢谢。 最佳答案 试试这个:gitclonehttps://github.com/sonota/anbt-sql-for

sql - Arel中 "where exists"怎么办

如何在Arel中执行包含“whereexists”的查询?例如,在这样的查询中显示至少有一个订单的所有供应商:SELECT*FROMsuppliersWHEREEXISTS(SELECT*FROMordersWHEREsuppliers.supplier_id=orders.supplier_id);我在Arel文档中看到“存在”http://rubydoc.info/gems/arel/2.0.7/Arel/Nodes/Exists但我在使用它时遇到了问题。 最佳答案 给你:suppliers=Supplier.arel_tabl

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d

ruby-on-rails - 向路由添加新操作

我在用户Controller中得到了这些ActionclassUsersController我希望能够/users/another_new并从某种链接调用:method=>:another_create使/users/another_new我得到了以下config/routes.rbget'/users/another_new':to=>'users#another_new'resources:users我的问题是这是否是添加get的正确方法以及我如何添加another_create方法。 最佳答案 在你的config/routes

ruby-on-rails - 如何在 Ruby on Rails 中将数字强制为小数点后 10 位?

我的数据库中的纬度和经度值精确到小数点后10位:+----+---------------+-----------------+|id|lat|lng|+----+---------------+-----------------+|55|34.4208305000|-119.6981901000||56|30.2671530000|-97.7430608000|我需要查询数据库进行匹配,但我当前的变量是一个只有6位小数的float:self.lat=>30.267153如何将我的float转换为具有额外的小数位以便获得匹配项?myloc=Marker.where("lat=?",se